  //给你一个整数数组 nums ，数组中的元素 互不相同 。返回该数组所有可能的子集（幂集）。
//
// 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
//
//
//
// 示例 1：
//
//
//输入：nums = [1,2,3]
//输出：[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]
//
//
// 示例 2：
//
//
//输入：nums = [0]
//输出：[[],[0]]
//
//
//
//
// 提示：
//
//
// 1 <= nums.length <= 10
// -10 <= nums[i] <= 10
// nums 中的所有元素 互不相同
//
//
// Related Topics 位运算 数组与矩阵 回溯与递归 👍 2028 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
function subsets(nums: number[]): number[][] {

    function backtracking(startIndex, temp) {
        res.push([...temp])
        for (let i = startIndex; i < nums.length; i ++) {
            temp.push(nums[i])
            backtracking(i + 1, temp)
            temp.pop()

        }
    }
    let res : number[][] = []
    backtracking(0,[])
    return res
};
//leetcode submit region end(Prohibit modification and deletion)
